<template>
  <div class="article-list" ref="listRef">
    <van-pull-refresh
      v-model="refreshing"
      :success-text="refreshTip"
      @refresh="onRefresh"
    >
      <van-list
        v-model="loading"
        :finished="finished"
        finished-text="没有更多了"
        :error.sync="error"
        error-text="请求失败，点击重新加载"
        @load="onLoad"
      >
        <ArticleItem
          v-for="(item, index) in list"
          :key="index"
          :article="item"
        ></ArticleItem>
        <!-- <van-cell
          v-for="(item, index) in list"
          :key="index"
          :title="item.title"
        /> -->
      </van-list>
    </van-pull-refresh>
  </div>
</template>

<script>

import { getArticleList } from '@/api/article'
import ArticleItem from '@/components/article-item/index.vue'
export default {
  name: 'ArticleList',
  props: {
    channel: { type: Object, required: true }
  },
  components: {
    ArticleItem
  },
  data () {
    return {
      list: [],
      loading: false,
      finished: false,
      timestamp: Date.now(),
      error: false,
      refreshing: false, // 是否下拉
      refreshTip: ''
    }
  },
  activated () {
    // console.log('activated')
    this.$refs.listRef.scrollTop = localStorage.scrollTop
  },
  deactivated () {
    // console.log('deactivated')
  },
  created () {
    // console.log('created')
  },
  mounted () {
    // console.log('mounted')
    this.$refs.listRef.onscroll = function () {
      localStorage.scrollTop = this.scrollTop
    }
  },
  methods: {
    async onRefresh () {
      try {
        const { data: { data: { results } } } = await getArticleList({
          channel_id: this.channel.id, // 频道ID
          timestamp: Date.now(), // 你可以把 timestamp 理解为页码
          with_top: 1 // 如果请求第1页数据：当前最新时间戳 Date.now
        })
        // 模拟随机失败的情况
        // if (Math.random() > 0.5) {
        //   JSON.parse('{adsa,dhas}')
        // }
        // 2. 将数据追加到列表的顶部
        this.list.unshift(...results)
        // 3. 关闭下拉刷新的 loading 状态
        this.refreshing = false
        // 更新下拉刷新成功提示的文本
        this.refreshTip = `更新了${results.length}条数据`
      } catch (error) {
        this.refreshing = false
        this.refreshTip = '请稍后再试'
      }
    },
    async onLoad () {
      try {
        // 1. 请求获取数据
        const { data: { data: { pre_timestamp: timestamp, results } } } = await getArticleList({
          channel_id: this.channel.id, // 频道ID
          timestamp: this.timestamp, // 你可以把 timestamp 理解为页码
          with_top: 1 // 如果请求第1页数据：当前最新时间戳 Date.now
        // 如果请求之后的数据，使用本次接口返回的数据中的 pre_timestamp
          // 时间戳，请求新的推荐数据传当前的时间戳，请求历史推荐传指定的时间戳
          // 是否包含置顶，进入页面第一次请求时要包含置顶文章，1-包含置顶，0-不包含
        })

        // 模拟随机失败的情况
        // if (Math.random() > 0.5) {
        //   JSON.parse('{adsa,dhas}')
        // }

        // 2. 把请求结果数据放到 list 数组中
        this.list.push(...results)
        // 数组的展开操作符，它会把数组元素一个一个拿出来

        // 3. 本次数据加载结束之后要把加载状态设置为结束
        this.loading = false
        // 4. 判断数据是否全部加载完成
        if (results.length === 0) {
        // 没有数据了，将 finished 设置为 true，不再 load 加载更多了
          this.finished = true
        } else {
        // 更新获取下一页数据的时间戳
          this.timestamp = timestamp
        }
      } catch (error) {
        // 展示错误提示状态
        this.error = true
        // 请求失败了，loading 也需要关闭
        this.loading = false
      }
    }
  },
  watch: {},
  computed: {}
}

</script>

<style lang="less" scoped>
.article-list {
  overflow-y: auto;
  height: 79vh;
}
</style>
